CLAIMS 

What is claimed is: 

1 . NA method comprising: 

reaomg a Une of data from a file containing source code written in a high level language; 
generatmg a stream of tokens from said line of data, said stream of tokens representing 

any of a specific t>pe of macro in said line of data as being expanded while other 

types ormacros are not expanded; 
parsing said streanrof tokens; 

inserting commands repi;esenting operations to be performed by a macro into said stream 

of tokens if a macrons present; and 
writing said stream of token toVi output file. 

2. The method of claim 1, wherein said generating a stream of tokens further comprises: 
determining whether tokens are present ik either an input file, a lookahead buffer, or a 

macro expansion list; and \ 
responsive to finding tokens, reading said tokens first from said lookahead buffer, then 

from said macro expansion list, then from skid input file; 
presenting said tokens to a parser so that any macro inlaid line of data appears to have 

been expanded. \ 

3. The method of claim 1, wherein said parsing further comprised 
determining a type of token read; \ 
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responsive to determining that the token is an end-of-line, processing an input Une of 
tokens; 

h^^nsive to determining that the token is not a symbol, adding the token to a current 
ine token list; 

responsive determining that the token is a symbol that indicates a beginning of a macro 
definition recording the macro name and macro definition and adding the tokens 
to a lookahead buffer; and 

responsive to determimiig that the token is a symbol that does not indicate a beginning of 
a macro definition^ adding the token to a current line token list. 

4. The method of claim 1 , wherem said writing comprises: 

writing expanded macro tokens tcr^aid output file if said macro is of said specific type of 
macro; and 

writing an original macro call to said ou'^^ut file if said macro is not said specific type of 
macro. 

5. The method of claim 1, wherein said source code, written in a high level language 
comprises a hardware description language (HDL) for representing hardware designs. 

6. The method of claim 1, wherein said specific type of macto comprises a scan macro. 



7. A method of scan insertion comprising: 



Docket No. 42390P9571 16 
Express Mail No. EL750 127621 US 



V 



readiHg a hardware description language (HDL) representation of a hardware design, the 
^ including a plurality of macro definitions some of which relate to scan 
insertion 

creating a token strearb\based on the HDL representation that includes multifaceted 

tokens that can be Mdden from or made visible to a subsequent parsing process by 
expanding the plurality\)f macro definitions and making tokens associated with 
scan macros visible to the s^^bsequent parsing process and marking other tokens as 
hidden; 

performing scan insertion by parsing tho"^ of the muhifaceted tokens that are visible to 

the parser and adding appropriate sran commands; and 
generating a scan inserted HDL file containing^expanded versions of the macro 

definitions which relate to scan insertion ft(jit that omits expanded versions of 

those that do not relate to scan insertion. 



8. The method of claim 7, wherein said HDL comprises a high-level language. 

9. The method of claim 7, wherein said hardware design represel^ts an integrated circuit 
design. 



10. A system comprising: 

a storage device having stored therein one or more routines for selectiyely expanding 
macros within source code; and 
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a processor coupled to the storage device for executing the one or more routines for 
selectively expanding macros within source code which, when executing said 
imtine: 

reads\Jine of data from a file containing source code written in a high level 
iage; 

generates a srream of tokens from said line of, said stream of tokens representing 
any of a\pecific type of macro in said line of data as being expanded 
while otheXtypes of macros are not expanded; 
parses said stream oiVtokens; 

inserts commands representing operations to be performed by a macro into said 

stream of tokens rf a macro is present; and 
writes said stream of token\o an output file. 



1 1 . The system of claim 10, wherein said generating a stream of tokens fiirther comprises: 
determining whether tokens are present vs^ either an input file, a lookahead buffer, or a 

macro expansion list; and 
responsive to finding tokens, reading said tol^ns first from said lookahead buffer, then 

from said macro expansion list, then from said input file; 
presenting said tokens to a parser so that any macr^ in said line of data appears to have 

been expanded. 



12. The system of claim 10, wherein said parsing fiirther con^prises: 
determining a type of token read; 
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responsive to determining that the token is an end-of-Une, processing an input line of 
ttokens; 

responsiveto determining that the token is not a symbol, adding the token to a current 
line tOKian list; 

responsive to determining that the token is a symbol that indicates a beginning of a macro 
definition, recording the macro name and macro definition and adding the tokens 
to a lookahead buffer; and 

responsive to determining that the token is a symbol that does not indicate a beginning of 
a macro definition, adaiiig the token to a current line token list. 



13. 



V 



The system of claim 10, wherein saixi writing comprises: 

writing expanded macro tokens to saio^output file if said macro is of said specific type of 
macro; and 

writing an original macro call to said outpu\file if said macro is not said specific type of 
macro. 



14. The system of claim 10, wherein said source code written in a high level language 
comprises a hardware description language (HDL) fo\ representing hardware designs. 

15. The system of claim 10, wherein said specific type of macto comprises a scan macro. 



16. A machine-readable medium having stored thereon data representing sequences of 

instructions, the sequences of instructions which, when execute^ by a processor, cause 
the processor to selectively expand macros by: 
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reaoing a line of data from a file containing source code written in a high level language; 
generating a stream of tokens from said line of, said stream of tokens representing any of 

a sp^ecific type of macro in said line of data as being expanded while other types 

of machos are not expanded; 
parsing said stream\f tokens; 

inserting commands representing operations to be performed by a macro into said stream 

of tokens if a macrc* is present; and 
writing said stream of token an output file. 

17. The machine-readable medium of oJaim 16, wherein said generating a stream of tokens 
further comprises: \ 

determining whether tokens are present m either an input file, a lookahead buffer, or a 
macro expansion list; and \ 



responsive to finding tokens, reading said tokens first from said lookahead buffer, then 

from said macro expansion list, then froAsaid input file; 
presenting said tokens to a parser so that any macro\n said line of data appears to have 
been expanded. \ 

18. The machine-readable medium of claim 16, wherein said parsing further comprises: 
determining a type of token read; \ 
responsive to determining that the token is an end-of-line, processing an input line of 

tokens; \ 
responsive to determining that the token is not a symbol, adding the token to a current 




line token list; 
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responsive to determining that the token is a symbol that indicates a beginning of a macro 
^definition, recording the macro name and macro definition and adding the tokens 
tcm lookahead buffer; and 
responsive to^^etermining that the token is a symbol that does not indicate a beginning of 
a macro definition, adding the token to a current line token list. 



19. The machine-readable medium of claim 16, wherein said writing comprises: 
writing expanded macro toK^ns to said output file if said macro is of said specific type of 

macro; and 

writing an original macro call to ^id output file if said macro is not said specific type of 
macro. 

20. The machine-readable medium of claim 16,Nvherein said source code written in a high 
level language comprises a hardware descriptioi^ language (HDL) for representing 
hardware designs. 



21 . The machine-readable medium of claim 16, wherein saiaV§pecific type of macro 
comprises a scan macro. 



22. A machine-readable medium having stored thereon data representing sequences of 

instructions, the sequences of instructions which, when executed by ayprocessor, cause 
the processor to perform scan insertion by: 
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reading a hardware description language (HDL) representation of a hardware design, the 
HDL including a plurality of macro definitions some of which relate to scan 
insertion; 

creating a ibl^n stream based on the HDL representation that includes multifaceted 

tokens thahqan be hidden from or made visible to a subsequent parsing process by 
expanding the plurality of macro definitions and making tokens associated with 
scan macros visible the subsequent parsing process and marking other tokens as 
hidden; 

performing scan insertion by parsin^hose of the multifaceted tokens that are visible to 

the parser and adding appropriate^can commands; and 
generating a scan inserted HDL file containinkexpanded versions of the macro 

definitions which relate to scan insertion ma| that omits expanded versions of 

those that do not relate to scan insertion. 



23. The machine-readable medium of claim 22, wherein said HDi^ comprises a high-level 
language. 



24. The machine-readable medium of claim 22, wherein said hardware design represents an 
integrated circuit design. 
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